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Verfahren zum Erstellen eines Kommunikationsablaufs zwischen mindestens zwei 
Instanzen und Protokolitester hierfur 



(57) Das vorliegende Verfahren ist gekennzeichnet 
durch folgende, am Protokolitester ausfuhrbare Schrit- 
te: a) Auswahlen der an der Kommunikation beteiligten 
Instanzen; b) Auswahlen einer Protokollschicht, auf de- 
ren Grundlage die Kommunikation zwischen den aus- 
gewahlten Instanzen ablaufen soil; c) Auswahlen derje- 
nigen abstrakten Kommunikationsschnittstellen der 
Protokollschicht, die an der Kommunikation beteiligt 
sind; d) Auswahlen der Kommunikationsdaten; e) auto- 
matisches Erstellen eines zwischen den mindestens 



zwei Instanzen ausfuhrbaren Kommunikationsablaufs 
durch den Protokolitester, auf der Grundlage des Aus- 
wahlen in den Schritten a) bis d), wobei die Auswahl von 
Schritt c) und/oder Schritt d) graphisch erfolgt und den 
dabei auswahlbaren Parametern Beschreibungsdatei- 
en zugeordnet sind, die in Schritt e) zur Erstellung eines 
zwischen den Instanzen ausfuhrbaren Kommunikati- 
onsablaufs verwendet werden. Die Erfindung betrifft 
weiterhin einen Protokolitester, in dem das erfindungs- 
gemaGe Verfahren realisiert ist. 
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Beschreibung 

[0001] Die vorliegende Erfindung betrifft ein Verfahren zum Erstellen eines Ablaufs einer zwischen mindestens zwei 
Instanzen ablaufenden Kommunikation, wobei eine Instanz ein Protokolltester ist. Sie betrifft uberdies einen Protokoll- 
tester, in dem dieses Verfahren realisiert ist. 

[0002] lm Bereich des Protokolltests ist es notig, den Kommunikationsablauf . durch den ein Test beschrieben wird 
eindeutig zu spezifizieren, so daf3 dieser Ablauf automatisch maschinell ausgefuhrt werden kann Sprachen wie zum 
Beispiel TTCN (Tree and Tabular Combined Notation) ermoglichen dies, sind aber komplex und fur einen ungeubten 
Leser schwer zu verstehen. TTCN hat sich im Bereich des Conformance Testing durchgesetzt, da diese Tests sehr 
umfangreich sind und TTCN solche umfangreichen Tests gut unterstutzt. Daneben gibt es diverse proprietare Testbe- 
schreibungssprachen. Urn die Verstandlichkeit zu erleichtern, wird zu Dokumentations- und Beschreibungszwecken 
einfacher Ablaufe die standardise Sprache MSC (Message Sequence Charts) verwendet. Detailliertere Angaben 
zu MSC konnen der ITU-T Z.120 entnommen werden, die durch diese Bezugnahme in den Offenbarungsgehalt der 
vorhegenden Anmeldung aufgenommen wird. Bei MSC handelt es sich urn genormte Ablaufdiagramme auch Pfeil- 
diagramme Oder X-Diagramme genannt. Sie sind unabhangig von Programmierkenntnissen zu verstehen Eine auto- 
matische Ausfuhrung von mit MSC beschriebenen Kommunikationen ist auf Protokolltestern jedoch nicht moglich Urn 
ausfuhrbare Tests zu erhalten miissen daher sogenannte Scripts geschrieben werden, was eine Einarbeitung des 
Anwenders in die jeweilige Programmiersprache erforderlich macht. Eine allgemein verstandliche Dokumentation muB 
zusatzl.ch erstellt werden. Fur einen Test miissen daher getrennt zum einen eine graphische und textuelle Dokumen- 
tation erstellt werden, zum anderen ein Source-Code oder ein ausfuhrbarer Binary. 

[0003] Aus diesem Stand der Technik ergeben sich eine Vielzahl von Nachteilen: Haufig ist eine Konvertierung be- 
stehender Tests notig, so da3 die Gefahr von Inkonsistenzen besteht. Konfigurationsinformationen sind oft in den 
Spezifikationen der Testkommunikationen nicht oder zumindest nicht maschinenlesbar oder nicht menschenlesbar 
cnthalten. Die verwcndetcn Sprachen stcllcn haufig proprietare Ansatze dar die von Gerat zu Gerat verschiedon sind 
und neu erlernt werden miissen. Der Anwender wird nicht oder nur rudimentar bei der Erstellung der Nachrichten und 
Ereignisse mit Protokoliwissen unterstutzt. 
[0004] Der vorliegenden Erfindung iiegt daher die Aufgabe zugrunde, die Nachteile der oben dargestellten, aus dem 
Stand der Technik bekannten Vorgehensweise zu iiberwinden. 
[0005] Diese Aufgabe wird gefost durch ein Verfahren gemaB Anspruch 1. 
30 [0006] GemaB einem weiteren Aspekt der Erfindung wird ein Protokolltester zur Verfiigung gestellt mit den Merk- 
malen von Anspruch 8. 

[0007] Die Erfindung erlaubt es, den gewiinschten Kommunikationsablauf in einer leicht verstandlichen graphischen 
standardisierten Form, beispielsweise MSC, zu erstellen. Durch die erfindungsgemaBe Losung ist es nunmehr moglich' 
die Kommunikattonsschnittstellen und/oder die Kommunikationsdaten graphisch zu spezifizieren. Mit MSC selbst allein 
ist dies nicht moglich. Dadurch daB den graphisch auswahlbaren Parametern Beschreibungsdateien zugeordnet sind 
wird die Moghchkeit bereitgestellt, daB der Protokolltester automatisch die vom Benutzer ausgewahlten Parameter in 
eine ausfuhrbare Version eines KommunikationsabJaufs transformiert. Durch die graphische Bereitstellung von Para- 
meterzusammenstellungen, aus denen der Benutzer auswahlen kann, wird der Benutzer in jeder Phase mit konfigu- 
rationsspezifischer und protokotlspezifischer Information unterstutzt. Neben einer kurzen Einweisung in einen Gra- 
phikstandard, beispielsweise MSC, benotigt der Benutzer kein weiteres Vorwissen. urn das erfindungsgemaBe Ver- 
fahren erfolgreich anwenden zu konnen. Die graphische Darstellung erfolgt auf einer Anzeigeeinheit, beispielsweise 
einem Monitor oder einem Bildschirm. 

[0008] Dokumentation und implementierung wird auf diese Weise in einem Vorgang erledigt, wobei der Benutzer 
immer die Dokumentationssicht auf einer graphischen Benutzeroberflache sieht. 

[0009] Die BedienungsfreundlichkeitfurdenBenutzersteigtumsomehrjemehrAuswahlen dem Benutzer graphisch 
zur Verfugung gestellt werden. In einer besonders bevorzugten Ausfuhrungsform der Erfindung sind daher mit Bezug 
auf das erfindungsgemaBe Verfahren, alle Auswahlschritte gemaB a) bis d) graphisch unterstutzt, wobei alien mit den 
Auswahlmitteln auswahlbaren Parametern Beschreibungsdateien zugeordnet sind. die dann in Schritt e) zur Erstellung 
ernes zwischen den Instanzen ausfuhrbaren KommunikationsabJaufs verwendbar sind. 
so [0010] Die abstrakten Kommunikationsschnittstellen umfassen vorzugsweise sogenannte Service Access Points 
(SAPs), die Kommunikationsdaten vorzugsweise sogenannte Protocol Data Units (PDUs) und/ oder sogenannte Ab- 
stract Service Primitives (ASPs). Hierbci handelt es sich urn Primitive, d. h. Datcnpakcte. mit denen sich verschiedene 
Kommunikationsschichten derselben Instanz untereinander verstandigen. Ein SAP ist demnach ein Punkt an dem 
verschiedene ASPs ausgetauscht werden konnen. Vorzugsweise enthalten ASPs PDUs, wobei ublicherweise iede 
55 PDU einzeln zu erstellen ist. 

[001 1 ] Die Auswahl der Kommunikationsdaten kann zwei Teilschritte umf assen : zunachst das graphische Auswahlen 
eines Datenformats, dann den graphischen Aufbau einer Kommunikationsabfolge zwischen den beteiligten Instanzen 
[0012] Hmsichtlich des zuletzt genannten Teilschritts kann die Moglichkeit vorgesehen werden, Source-Code einzu- 
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K Die zuvor erwahnten Merkmale der Erfindung gelten in entsprechender Weise fur einen ertindungsgemaBen 

raMffl 0 ' wSre vorteilhafte Weiterbildungen der Erfindung sind in den Unteranspruchen definiert. 

[0015] Ein Ausfuhrungsbeispiel w.rd im folgenden, unter Hinweis auf die beigefugten Ze.chnungen, naher beschne- 

ben. Es stellen dar: 
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Figur 1 eine erste graphische Benutzeroberflache, wie sie bei dem ertindungsgemaBen Verfahren Anwendung 
findet; 

Figur 2 eine zweite graphische Benutzeroberflache, wie sie bei dem ertindungsgemaBen Verfahren Anwendung 
findet; 

Figur 3 die Benutzeroberflache von Figur 2 in einem anderen Darstellungsmodus; 
Figur 4 die Benutzeroberflache von Figur 2 in einem weiteren Darstellungsmodus; 

Figur 5 eine dritte graphische Benutzeroberflache, wie sie bei dem ertindungsgemaBen Vertahren Anwendung 
findet; 

Figur 6 die Benutzeroberflache von Figur 5 in einem anderen Darstellungsmodus; und 
Figur 7 die Benutzeroberflache von Figur 5 in einem weiteren Darstellungsmodus. 

[00161 Figur 1 zeigt eine graphische Benutzeroberflache 10, die in einem ersten Schritt auf graphischem Wage die 
Auswlhl der an eine'r Kommunikation beteiligten Instanzen ermoglicht. Graph.sches Auswahlen , im 

der vorliegenden Erfindung bedeutet, daB ein Symbol oder ein Textvorsch.ag graph.sch auf emer graph.schen 
Benutzeroberflache, beispielsweise einem PC-Bildschirm, angezeigt wird und durch sohhchtes Akt,v,eren d^be - 
spie'sweise durch Anklicken mit einer Maus, ausgewahlt werden kann. Eine der Instanzen ,st e,n Protoko.ltester, auf 
dem das erfindungsgemaBe Verfahren zur Vertugung gestellt wird, wobei der Protokolltester ,m vorlregenden FaH erne 
Komponente TC I emuliert. Mit den beiden Icons "Add" 12 und "Delete" 14 kann der Benutzer we.tere ns anzen 
Sr g en bezrehun^weise aufgelistete Instanzen loschen. .n einem Feld 16 ist die Zusammenstel ung der Instanzen 
aufgeSet wThrend sie in einem Feld 1 8 als Diagramm angezeigt wird. In einem Feld 1 9 kann der Name der Instanz^ 
fn FeldTo derTyp der Instanz festgelegt werden. Zwei Icons 22, 24 ermoglichen dem Benutzer, s,ch von e.ner Stufe 
derDefi^ 

sowie auch in Richtung iibergeordneter Darstellung. Eine »Cancel"-Taste 26 ermoghcht das Verlassen emer Stufe, 
wobei die Irgenommenen Anderungen ruckgangig gemacht werden. Eine "Help'-Taste 28 bietet dem Benutzer we,- 

loSTSeSFigur 2 in der eine weitere Darstellung der Benutzeroberflache 10 gezeigt ist, hat der voriiegende 
Eun»nsab?auf den Namen Gateway_1 , siehe Feld 22. An ihm nimmt tei. eine erste Instanz TC_1 , gemaB Feld 
24 sow^e Te zweL Instanz IUT 1 . gemaB Feld 26. Das emulierte Protokol. ist gemaB Feld 28a vom Typ ,sdnl2, 
wtbei"Feld28bwet r e,zurAusw^^ 

Tur weiteren Bearbeitung auswah.bare Kommunikationsab.aufe angeboten werden. Die m,t Bezug auf F.gur 1 be- 
schrbenen Icons 12 14 22, 24, 26. 28 finden sich in vergleichbarer Form mit vergleichbarer Funkt.on w.eder, s.ehe 
auch die noch folaenden Benutzeroberflachen, und werden daher nicht nochmals beschneben. 
[0018? F gur 3 zegfdie Benutzeroberflache 10 von Figur 1 in einem anderen Darstellungsmodus und zwar zur 
Auswahl eines SAPs, siehe Feld 32a. Im Feld 32b werden weitere SAPs zur Auswah. angeboten. Alle ,n Feld 32b 
daraestellten SAPs werden zu der gewahlten Emulation isdnl2 angeboten. 

Rguf zeigt eine weitere Darstellungslorm der Benutzeroberflache 1 0 von Figur 2, wobei nunmehr ,n einem 
FeW 34 aus sogenannten Message Pools ein Format fur die Kommunikationsdaten (ASPs. PDUs) verwendet w.rd. 
[0020] FiguTzeigt eine weitere Benutzeroberflache 36, die in einem Feld 38 dem Benutzer diverse « Jom«jonjn 
zur Verfugung stollt Zum einen die von ihm ausgowahlten Instanzen, dann das gemaB den F.guren 1 4 verembarto 
Testszenario (Gateway 1) sowie das Datenformat (Message Pools). Im folgenden sol. zunaohst auf F,gur 6 Bezug 
Snommen werden: Die Benutzeroberflache 36 weist eine Vielzah. von Icons 40 auf, die, ^s ^ZTs^ 
Textverarbeitung oder Graphikbearbeitung bekannt, beispielsweise unter Verwendung e.ner Maus ankhckbar s nd. 
Unter Verwendung dieser Icons laBt sich in einem Feld 42 in graphischer Weise ein Kommun.kat.onsablau ertrtlar 
Fiaur 6 zeidt die Moglichkeit des Einbaus von Code in der Programmiersprache Forth (Draft Proposal ANSI Standard 
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Programmiersprache konnen weitere Eingabemasken vorgesehen werden. 

[0021] Zuriick zu Figur 5: Hier wird als Beispiei fur einen Abschnitt eines Kommunikationsablaufs in Feld 48 darge- 
stellt, wie zunachst alternativ die ASPs DL_ESTABLISH_CNF oder DISESTABLISH JND von einer Instanz erwartet 
werden. Daraufhin wird ein Timer T_ Waitlnit der Lange 5s gestartet und das Ablaufen des Timers abgewartet. 
[0022] Figur 7 zeigt, wie eine isdn-PDU "SETUP_1 " als Sendenachricht in das graphisch erstellte Ablaufdiagramm 
eingefugt wird. In einer Eingabemaske 50 werden ASPs mit PDUs aus dem zuvorausgewahlten Message Pool ange- 
boten. In einem optisch hervorgehobenen Feld 52 kann die ausgewahlte PDU eingetragen werden. In einem Feld 54 
wird weitere Information zur ausgewahlten ASP beziehungsweise PDU dem Benutzer dargeboten. 
[0023] Auf die soeben beschriebene Art und Weise laBt sich somit ein Kommunikationsablauf erstellen, wobei be- 
vorzugt alien auswahlbaren Parametern Beschreibungsdateien zugeordnet sind, die zum automatischen Erstellen ei- 
nes zwischen den Instanzen ausfuhrbaren Kommunikationsablaufs durch den Protokolltester automatisch miteinander 
verwendbar sind. 

[0024] Bei der Erzeugung eines ausfuhrbaren Codes wirken drei Komponenten zusammen: Zunachst die graphi- 
schen Benutzeroberflachen, die die gewahlten Parameter, insbesondere auch die Kommunikationsabfolge in einer 
internen Struktur speichert. Dann ein Compiler, der die gewahlten Parameter in temporare Files ubersetzt und 
schlieBlich ein Linker, der dies temporaren Files liest und in die gewahlte Interpreter-Scriptsprache, beispielsweise 
ANS Forth, umsetzt. Dabei wird der gesamte Kommunikationsablauf wie er vom Benutzer definiert wurde in ein Script- 
file geschrieben. 

[0025] Im Anhang A1 ist passend zu den beschriebenen Figuren der automatisch vom Protokolltester generierte 
20 Code wiedergegeben. 
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Anhang Al 



( ***** Tektronix MSC-LinJcer <VO.92.0> builds scenario 'isdn_user' **-*- forth 
) 

- $MSC$Script$" find [if] forget $MSC$Scripn$ [then] drop variable 
$MSC$Script$ 

• emul n find 0= [if] loadm enul [then] drop 
« error" find 0= [if] loadm error [then] drop 

■ mbslib" find 0= [if] loadm mbslib [then] drop 

■ mforth" find 0= [if] loadm mforth [then] drop 
default-order 

v_trace 
v screen 

{ >>>>>>>>>> Allocation <<<<<<<<<< ) 

( create instance variables and constants... ) 

CREATE $MSC$_InstanceVars 4 ALLOT 



1 CONSTANT MSC_NUM_OF_INSTANCES 

$MSC$_InstanceVars MSC_NUM_OF_INSTAKCES 4*0 FILL 
( create timer variables and constants. . . ) 
CREATE $MSC$_TimerVars 4 0 ALLOT 
$MSC$_TimerVars 4 0 0 FILL 
CREATE MSCJTIMER 20 ALLOT 
MSCJTIMER 20 0 FILL 
30 5 CONSTANT MSC_NUM_OF JT I MERS 

( create pool variables and constants... ) 
CREATE $MSC$_PoolVars 4 ALLOT 

I CONSTANT MSC_NUM_OF_POOLS 
$MSC$__PoolVars 4 0 FILL 

35 ( create message variables and constants ... ) 

CREATE $MSC$_MsgVars 132 ALLOT 
$MSC$_MsgVars 132 0 FILL 

II CONSTANT MSC_NUM_OF_MES SAGES 
CREATE $MSC$_MsgDecodeVars 4 ALLOT 

40 $MSC$_MsgDecodeVars 4 0 FILL 

I CONSTANT M£C_NUM_OF_MS GDE COD EV ARS ( one per TM } 
CREATE $MSC$_MsgFolderVars 44 ALLOT 
$MSC$_MsgFolderVars 44 0 FILL 

II CONSTANT MSC_N~JM_OF_FOLDERS 

CREATE $MSC$_EventStructureVars MSC_NUMJDF__POOLS MSC_KTJMJDF__INSTANCSS * 4 * 
ALLOT 

$MSC$_EventStructureVars MSC_NUM_0F_POOLS MSC_NUMJ)F_INSTANCES * 4 * 0 FILL 
CREATE $MSC$J*sgSizeVars 4 ALLOT 
50 $MSC$_MsgSizeVars 4 0 FILL 

variable $MSC$_MsgMatched? 

( create temporary variables and constants ... ) 
variable $MSC$JTempFolderKandle 
variable $MSC$_PDecoutVar 
55 ( create startstate variables ... ) 
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variable $MSC$_Req- State 

< »>>=»>>>>=> Constants «<«««< ) 

( create mapping of gateway name to pool index ) 

0 constant MSC-GW-Gateway_l \ Mapping Gatewayname 'Gateway_l' -> Poolindex '0 

( >>>>>>>>>:> Variables <<<<<<<<<< ) 
variable MSC-VAR-Cateway_l - SAP I 
variable MSC-VAR-Gateway_l-TEI 

( >>>>>>>>>> Commands <<<<<<<<<< ) 
include pc :boot : /share/pf e/msc_lib.4th 

( constructor word ... ) 
: $MSC$_Constructor ( ) 

" Cannot open pool * pc : c : /ki297/MBS-Pools/STK-et si 93-pooli . pdc' - - 
pc:c:/ki297/MBS-Pools/STK-etsi93-pooll.pdc'< 0 $MSC$_OpenPool \ open pool 
'pC:C: /kl297/MBS-Pools/STK-etsiS3-pooll .pdc' 

M Cannot open folder 'PR0T<ETSI> send to EMUL<isdnl2> ' « " PR0T<ETSI> send 
to EMUL<isdnl2>" 0 8 $MSC$_OpenFolder \ open folder 'PR0T<ETSI> send to 
EMUL<isdnl2>' within pool 'pc: c:/kl2 97/MBS -Pool s/STK-etsi93 -pool 1 .pdc' 

n Cannot init message 'rC0NN_l'" " rC0NN_l" 0 8 8 $MSC$_InitMsgVar \ init 
message 'rCONN_l< of pool 'pc:C:/kl297/MBS-Pools/STK-etsi93-pooll .pdc' 



Cannot open folder 'PR0T<ETSI=» send to EMUL<isdnl2>' " ■ PRCT<ETSI> send 
to EMUL<isdnl2>» 0 3 $MSC$_OpenFolder \ open folder 'PROT<ETSI> send to 
EMUL<isdnl2>' within pool 'pc: c : /kl297/MBS-?ools/STK-etsi93 -pooll . pdc' 

" Cannot init message ' rDL_E£TABLISH_CNF_l ' " ■ rDL_ESTABLISH_CNF_l n 033 
$MSC$_InitMsgVar \ init message ' rDL_ESTABLISH_CNP_l ' of pool 
' pc ; c : /kl297/MBS-Pools/STK-etsi93 -pool 1 . pdc ' 

n Cannot open folder • PROT<ETSl> send to EMUL<:isdnl2> ' ■ » PR0T<ETSI> send 
to EMUL<isdnl2>" 0 2 $MSC$_OpenFolder \ open folder 'PROT<ETSI> send to 
EMULcisdnl2>' within pool 'pc: c: /kI2 97/MES- Pool s/STK-etsi 93 -pooll . pdc' 

n Cannot init message ' sDL_ESTABLISH_REQ_l » » « sDL_ESTABLISH_REQ l n 0 2 2 
$MSC$_InitMsgVar \ init message ' sDL_ESTABLlSH_3EQ_l ' of pool 
•pc:C:/kl297/MBS-Pools/STK-etsi93-pooll.pdc' 

Cannot open folder 'PRCT<ETSI> send to EMUL<isdnl2> ' ■ • PR0T<ETSI> send 
to EMUL<isdnl2>» 0 4 $MSC$_OpenFolder \ open folder 'PROT<ETSI> send to 
EMUL<isdnl2>' within pool 'pc:c:/kl297/MBS-Pools/STK-etsi93 -pooll. pdc' 

" Cannot init message ' rDL_ESTABLISH_IND_l ' « " rDL_ESTAELISH_IND_l " 0 4 4 
$MSC$_InitMsgVar \ init message ' rDL_ESTABLISH_IND_l ' of pool 
'pc:c:/kl297/MBS-Pools/STK-etsi93 -pooll. pdc' 

" Cannot open folder 'PROT<ETSI> send to EMUL<isdnl2>' " " PROT<ETSI> send 
to EMUL<isdnl2>" 0 10 $MSC$_OpenFolder \ open folder '?ROT<ETSI> send to 
EMUL<isdnl2>' within pool 'pc: c:/kl297/MBS-Pools/STK-etsi93-pooll .pdc' 

" Cannot init message ' rREL_COM_l ' ■ " rREL_COM_l« 0 10 10 $MSC$_InitMsgVar 
\ init message ' rREL_C0M_i' of pool 'pc :c: /ki297/MBS-Pools/STK-etsi93- 
pooli .pdc' 

Cannot open folder 'PRCT<ETSI> send to EMUL<isdnl2>' ■ - PR0TcETSi> send 
to EMUL<is<±il2>" o 7 $MSC$_OpenFolder \ open folder 'PROT<ETSI> send to 
EMUL<isdnl2>' within pool ' pc : c ; /k!297/MBS-Pools/STK-etsi93 -pooll .pdc' 

■ Cannot init message ' rALERT_l ' " • rAIjERT_l» 0 7 7 $MSCS_InitMsgVar \ 
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init message * rALERT_l' of pool ' pc :C : /k!297/MBS-Pools/STK-etsi93 -pooll .pdc' 

» Cannot open folder ' PR0T<ETSI> send to EMUL<isdnl2> ' " n PR0T<ETSI> send 
to EMUL<i3dnl2>" 0 9 $MSC$_OpenFolcer \ open folder 'PR0T<ETSI> send to 
EMUL<isdnl2>' within pool 'pc:c: /kl297/MBS- Pocls/STK-etsi93 -pooll .pdc' 

■ Cannot init message 'sDISC_l'« " sDISC_l n 0 9 9 $MSC$_InitMsgVar \ init 
message ' sDISC_l' of pool 'pc:C: /kl297/MBS-Pools/STK-etsi93-pooll .pdc' 

" Cannot open folder 'PR0T<ETSI> send to EMUL<isdnl2>' - " PR0T<ETSI> send 
to EMUL<isdnl2>" 0 6 $MSC$_OpenFolder \ open folder '?ROT<ETSl> send to 
EMULcisdnl2>' within pool ' pc : c: /kl297/MBS-Pools/STK-etsi93-pooll .pdc' 

" Cannot init message ' rCALL_PROC_l ' » " rCALL_PROC_l n 0 6 6 
$MSC$_Ini-MsgVar \ init message * rCALI*_PROC_l ' of pool ' pc :c : /K1297/MBS- 
Pools/STK-etsi93 -pooll . pdc ' 

» Cannot open folder ' PR0T<:ETSI> send to EMUL«=isdnl2>' " n PR0T<2TSI> send 
to EMUL<isdnl2>" 0 1 $MSC$_OpenFolder \ open folder 'PR0T<ETSI> send to 
EMUL<isdnl2>' within pool 'pc :C: /kl297/MBS-Pools/STK-etsi93-pooll .pdC 

Cannot init message ' rMDL_ASSIGN_CNF_l' " " rMDL__ASSIGN_CNF_l n Oil 
$MSC$_InitMsgVar \ init message ' rMDL_ASSIGN_CNF_l ' of pool 'pc : c : /kl297/MBS- 
Pools/STK- etsi93 -pool 1 . pdc ' 

" Cannot open folder 'PR0T<ETSi> send to EMUL<isdnl2> '" " PR0T<STSI> send 
to EMUL<risdnl2>" 0 0 $MSC$_0pen Folder \ open folder 'PROT<ETSI> send to 
EMUL<isdnl2>' within pool 'pc : c : /kl297/MBS- Pools/STK-etsi93-pooll .pdc' 

•• Cannot init message ' sMDL_ASSIGN_REQ_l' " " sMDL _AS S I GN_REQ__ 1 " 0 0 0 
$MSC$_InitMsgVar \ init message ' sMDL_ASSIGN_REO_l ' of pool 'pc : c: /k!297/MBS- 
Pools /STK-etsi9 3 -pooll. pdc' 

" Cannot open folder 'PROT<ETSI> send to EMUL<isdnl2> ' ■ n PR0T<ETSI> send 
to EMUL<isdnl2> " 0 5 $MSC$_OpenFolder \ open folder 'PR0T<ETSI> send to 
EMUL<isdnL2>' within pool ' pc : c: /kl297/MBS-Pools/STK-etsi93-pooll .pdc' 

cannot init message 'sSETUP_l'" ■ sSETUP_l" 0 5 5 $MSC$_InitMsgVar \ 
init message 'sSETUP_l' of pool ' pc:c: /k!297/MBS-Pools/STK-etsi93-pooll .pdc' 

MSC- VAR-Gateway_l - SAP I " SAPI" " PROT<ETSI> send to 2MUL<isdnl2 > " 0 
$ MSC $ _As s i gnMSCVar 

MSC-VAR-Gateway_l-TEI " TEI n n FROT<ETSl> send to EMUL<isdnl2 > " o 
$MSC$_Ass ignMSCVar 

i 

{ destructor word ... ) 
: $MSC$_Destructor ( -- ) 
1 0 DO 

I $MSC$__GetPoolHandle kl2mbspool close DROP 
LOOP 



{ >>>>>>>>>> initialization <<<<<<<<<< ) 

5000 4 $MSC$_SetExtTimerVar \ init. timer 'T_Pause' of instance 'Phone' 
45O00 1 $MSC$_SetExtTimerVar \ init. timer 'T310' of instance 'Phone' 
4000 0 $M3C$_SetExtTimerVar \ init. timer 'T303' of instance 'Phone' 
30000 3 $MSC$_SetExtTimerVar \ init. timer 'T305' of instance 'Phone' 
200CO 2 $MSC$_SetExtTimerVar \ init. timer 'T_Call' of instance 'Phone' 
0 0 $MSC$_InitMsg \ Create kl2MBSevent structure for instance 'Phone' and 
gateway ' Gateway_l ' 
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TMO { >>>>>>>>>> stare of instance 
( Segments of Instance 'Phone': 



'Phone' <<<<<<<<<< ) 



5 


I Type 


Segment Name 


J State 


1 1 pnnt K 




I iNir | 


- no name - 


| 0000000000 


! ftoonnnnnni 

| UUUUUUUUU 1 


10 


! EN D ! 


- no name - 


! 0000000001 


j UUUUUUUUU 1 


! ooc ; 


START 


| 0000000002 


| 0000000006 

| UUUuUUUUU4 




j OOC j 


NULL 


j 0000000006 


| 0000000001 




; ooc ; 


CALLJNITIATED 


j 0000000007 


i 0000000003 




j DOC i 


CALL_PR0CEEDtNG 


i 0000000010 


{ 0000000003 


15 


; ooc | 


CALL J)EL I VEREDACTI V 


J 0000000013 


! 0000000002 




! DOC | 


DISCONNECTJIEGUEST 


| 0000000015 


! 0000000004 




| CONN ; 


NULL 


j 0000000019 


1 0000000001 




I CONN } 


CALL_IN1TIATED 


! 0000000020 


! 0000000001 i 




; conn ; 


CALL ^PROCEEDING 


| 0000000021 


■ 0000000001 j 


20 


| CONN ; 


CALLJJEL I VERED_ ACT I V 


I 0000000022 


1 0000000001 i 
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♦ + ) 

\ init segment 

0 STATE_INIT{ 

128 " TMO stares" $M£C$_TraceMsg 

0 $MSC$_ResetGotoModifierFlag \ init. instance 'Phone' 
4 $MSC$_lnitTimerVar \ init. timer 'T_Pause' 

1 $MSC$_InitTimerVar \ init. timer 'T310' 
0 SMSC$_I nit Time rVar V init. timer 'T3 03' 
3 SMSC$_InitTimerVar \ init. timer 'T3 05' 

2 $MSC$_InitTimerVar \ init. timer 'T_Call' 
( switch command for starcstate . . . ) 
$MSC$_Req- State @ CASE 

1 OF 2 NEW_STATE ENDOF 
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2 OF 6 NEW_ STATE ENDOF 
2 0 $MSC$_NewState ( goto START ) 
END CASE 
] STATE_INIT 

\ end segment 

1 STATE_INIT{ 

- instance 'Phone' stops" $MSC$_PrintString 

128 " TMO stops" $MSC$_TraceMsg 
} STATE_INIT 

1 STATE { 

( this is the end state - loop forever ) 

} STATE 

\ document segment ' START' 

2 STATE_INIT{ 

32 " Forthbox TE_cfg start » $MSC$_TraceMsg 
{ start forth box 'TE_cfg' ) " config lapd. General . Side=TE_PM" 
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EMU_ADMIN ( end forth box 'TE_cfg' } 

64 " Forthbox TE_cfg end " $MSC$_TraceMsg 

16 " Send message 'PROT<ETSI> send to EMUL<isdnl2>/sMDL_ASSlGN_REQ_l ' 
over gateway 'Gateway_l ' " $MSC$_TraceMsg 
5 - Cannot send message ' sMDL_ASSIGN_REQ_l ' " 0 0 0 $MSC$_Send Primitive 

) STATE_INIT 
2 STATE ( 

" Error while matching primitive ' rMDLJVSSIGN_CNF_l ' " 10 0 
$MSC$_RecvPrimitive 
10 ACTION { 

8 " Received message ' PROT<ETSI> send to 
EMUL<isdnl2>/rMDL_ASSIGN_CNF_l ' from gateway « Gateway_l ' " $MSC$_TraceMsg 
0 0 1 $MSC$_FreeEventStructure \ free event structure of message 
'PR0T<ETSI> send to EWUL<isdnl2>/rMDL_ASSIGN_CNF_l' and gateway 'Gateway_l' 
15 1 $MSC$_ResetMsgFlag \ message 'PR0T<ETSI> send to 

SMUL< isdnl 2 > / rMDL_AS S I3N_CNF_ 1 ' from gateway ' Gateway_l ' 

0 $MSC$_ResetGotoModif ierFlag 
16 M Send message 'PR0T<ETSI> send to 

EMUL<isdnl2>/sDL_ESTABLISH_REQ_l' over gateway 'Gateway_l ' " $MSC$_TraceMsg 

" Cannot send message ' sDL_ESTABLISH_REQ_l * - 2 0 0 
$MSC$_Send?rimitive 

3 0 $MSC$_NewState 
}ACTION 
? TM_T I MEOUT 
25 ACTI0N{ 

1 " unexpected timer event n $MSC$_TraceMsg 

} ACTION 

FALSE E-SAP Q 0 = OR 
ACTION) 

30 q unexpected message event " $MSC$JTraceMsg 

0 0 1 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to EMUL< isdnl 2>/rMDL_ASSIGM_CBIF_l ' and gateway 'Gateway^' 
} ACTION 
} STATE 

35 3 STATE_INIT{ 

3 $MSC$_ResetMsgFlag \ message » PROT<ETSI> send to 
EMUL<isdnl2>/rDL_ESTABLiSH_CNF_l' from gateway 'Gateway_i' 



40 

4 $MSC$_ResetMsgFlag \ message 'PROT<ETSI> send to 
EMUL<isdnl2>/rDL_ESTABLISH_IND_l ' from gateway 'Gateway_l' 

} STATE_INIT 
3 STATE { 

45 - Error while matching primitive ' rDL_ESTABLISH_CNF_l' " 3 0 0 

$MSCS_RecvPrimit ive 
ACTION { 

0 0 3 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSl> send to EMUL<isdnl2>/rDL_ESTABLISH_CNF_l ' and gateway 'Gateway_l 

0 0 4 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to EMDLci S dnl2>/rDL_ESTABLISH_IND_l ' and gateway 'Gateway_l 
0 $MSC$_SetGotoModi f ierFlag 
4 o $MSC$_NewState 
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) ACTION 

" Error while matching primitive ' rDL_SSTABLISH_IND_l ' ■ 4 0 0 
$MSC$_RecvPr imi t i ve 
ACTION { 

0 0 3 $MSC$_PreeEventStructure \ free event structure of message 
'PROT<ETSI> send to EMUL<isdnl2>/rDL_ESTABLISH_CNF_l ' and gateway 'Gatevay_l' 

0 0 4 $MSC$_FreeEventStructure \ free event structure of message 
'PROT<ETSI> send to EMUL<isdnl2>/rDL_3STABLISH_IND_l' and gateway 'Gateway__l' 

0 $MS C $_S e t Got oModifier Flag 
5 0 $MSC$_Newstate 

} ACTION 

? TM__T I MEOUT 

ACTION { 

1 " Unexpected timer event " $MSCS_TraceMsg 

0 0 3 SMSC$_FreeEventstructure \ free event structure of message 
'PROT<ETSI> send to EMTJL< i s dn 1 2 > / r DL_ES TAB LI S H_CN F_ 1 ' and gateway 'Gateway_l' 

0 0 4 $MSC$_FreeEventstructure \ free event structure of message 
'PROT<ETSI> send to EMUL<isdnl2>/rDL_ESTABLISH_IND_l' and gateway 'Gateway_l' 
] ACTION 

FALSE E-SAP @ 0 - OR 
ACTION { 

8 " unexpected message event " $MSC$_TraceMsg 

0 0 3 $M£C$_FreeEventS true cure \ free event structure of dessaae 
'PROT<ETSI> send to EMUL< i sdnl 2 > / rDL_ESTABLISH_CNF__l ' and gateway 'Gateway_l' 

0 0 4 $MSC$_FreeEv € ntStrjc-ure \ free event structure of message 
'PROT<ETSI> send to EMUL< i sdnl 2 > / r DL_E£ TAB LI S H_ IND_ 1 ' and gateway 'Gateway_l' 

} ACTION 
} STATE 
4 STATE { 

■ Error while matching primitive ■ rDL_ESTABLISH CNF 1'° 3 0 0 
$MSC$_RecvPrirait ive 
ACTTON{ 

8 ■ Received message 'PRCT<ETSI> send co 
EMDL<isdnl2>/rDL_ESTABLISH_CNF_l' from gateway 'Gateway_i ' ■ $MSC$__TraceMsg 

0 0 3 $MSC$_FreeEvent Structure \ free event structure of message 
'PR0T<ETSI> send to EMTJL<isdnl2>/rDL_ESTABLISH_CNF_I ' and gateway 'Gateway^' 

3 $MSC$_ResecMsgFlag \ message 'PR0T<ETSI> send to 
EMUL<isdnl2>/rDL_ESTABLISH_CNF_l' from gateway 'Gateway_l' 
0 SMSC$_ResetGot oModifier Flag 
6 0 $MSC$_NewState 
} ACTION 
?TM_TIMEOUT 
ACTI0N{ 

1 ■ Unexpected timer event " SMSC$_TraceMsg 
) ACTION 

FALSE E-SAP @ 0 = OR 
ACTION { 

8 " unexpected message event " $MSC$_TraceMsg 

0 0 3 $MSC$_FreeEvent Structure \ free event structure of message 
PROT<ETSI> send to EMUL<isdnl2>/rDL - ESTABLISH_CNF_l ' and gateway 'Gatevay_l' 
) ACTION 
} STATE 
5 STATE ( 
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" Error while matching primitive ' rDL_SSTABLISH_IND_l' " 4 0 0 
$MSC$_RecvPrimitive 
ACTION} 

8 ■ Received message 'PROT<BTSI> send to 
EMUL< isdnl 2 > / rDL_ESTABLISH_IND_l 1 from gateway 'Gateway_l ' " $MSC$_TraceMsg 

0 0 4 $MSC$_FreeEvent Structure \ free event structure of message 
'PR0T<ETSI> send to EMUTi<isdnl2>/rDL_ESTABLISH_IND_l' and gateway 'Gateway_l' 

4 $MSC$_ResetMsgPlag \ message ' PR0T<ETSI> send to 
EMUL<isdnl2>/rDL_ESTABLISH_IND_l' from gateway 'Gateway_l' 

0 $MSC$_ResetGotoModif ierFiag 
6 0 $MSC$_NewState 

} ACT ION 

? TM_T IMEOUT 

ACT I ON { 

1 ■ unexpected timer event " $MSC$_TraceMsg 
} ACTION 

FALSE E-SAP O 0 = OR 
ACTION { 

8 » Unexpected message event " $MSC$_TraceMsg 

0 0 4 $MSC$_FreeEvent Structure \ free event structure of message 
<PROT<ETSI> send to EMUL<isdnl2>/rDL_E£TABLISH_IND_l ' and gateway 'Gatewav_l' 
} ACT ION 
\ STATE 

\ document segment 'NULL' 

6 STATE_INIT{ 

16 ■ Send message 'PROT<ETSI> send to EMUL< isdnl 2>/sSETUP_l' over 
gateway 'Gateway_l ' " $MSC$_TraceMsg 

■ Cannot send message 'sSET~JP_l' fl 5 0 0 $MSCS_Send?rimitive 

2 " Timer 'T303' set with value '4000'" $MSC$_TraceMsg 
4000 0 $MSC$_SetTimer \ timer 'T303' 

19 0 $MSC$_NewState 
} STATE_INIT 



\ document segment ' CALL_INITIATED' 

7 STATE { 

- Error while matching primitive ' rCALL_PROC_l ' " 6 0 0 
SMSC$_Recvprimitive 

ACTION { 

0 0 6 $MSC$_FreeEventSt:ructure \ free event srnicture of message 
'PROT<ETSI> send to EMUL<isdnl2>/rCALL_PR0C_l ' and gateway 'Gateway_l' 
0 $MSC$_SetGotoModif ierPlag 
8 0 $MSC$_NewState 
} ACTION 

0 $MSC$_Timeout \ timer 'T3 03' 
ACTION { 



0 0 6 $MSC$ FreeEventStructure \ free event structure of message 
'PROT<BTSI> send to EMUL<isdnl2>/rCALL_PR0C_l' and gateway 'Gateway_l' 
0 $MSC$_SetGotoModif ierFiag 
9 0 $MSC$_NewState 
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} ACTION 
?TM_T IMEOUT 
ACTIONf 

5 1 " Unexpected timer event n $MSC$_TraceMsg 

0 0 6 $MSC$_PreeEvent Structure \ free event structure of message 
'PR0T<ETSI> send to EMXJL<isdnl2>/rCALL_PR0C_l ' and gateway 'Gateway_l' 
} ACTION 

FALSE E-SAP @ 0 = OR 
10 ACTION { 

8 " Unexpected message event n $MSC$_TraceMsg 

0 0 6 $MSC$_FreeEvent Structure \ free event structure cf message 
'PROT<ETSI> send to EMUL<isdnl2>/rCALL_PROC_l ' and gateway 'Gatevay_l' 
} ACTION 
*5 } STATE 

8 STATE { 

■ Error while matching primitive ' rCALL_PR0C_l »" 6 0 0 
$MSC$_Recv?rimitive 
ACTION { 

8 ■ Received message 'PR0T<ETSI> send to EMUL<isdnl2>/rCALI,_PROC 1' 
from gateway 'Gateway_l ' » $MSC$_TraceMsg 

0 0 6 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to EMUIi<isdnl2>/rCAXL_?ROC_l ' and gateway 'Gateway_l' 

6 $MSC$_ResetMsgFlag \ message 'PRCT<ETSI> send tc 
EMUL<isdnI2>/rCALL_PR0C_l' from gateway 'Gateway_l' 
0 $MSC$_ResetGotoModif ierFlag 
4 " Timer 'T303' reset" $MSC$_TraceMsg 

0 ?MSC$_ResetTimer \ timer 'T3 03' 

30 2 " Timer 'T310' set with value '45000'- $MSC$_TraceMsg 

450CO 1 $MSC$_SetTimer \ timer 'T310' 
20 0 $MSC$_NewSnate 
} ACTION 
? TM_T I MEOUT 
35 ACTION { 

1 M Unexpected timer event " $MSC$_TraceMsg 
} ACTION 

FALSS E-SAP @ 0 = OR 
ACTI0N{ 

40 8 " Unexpected message event " $MSC$_TraceMsg 

0 0 6 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to EMUL<isdnl2>/rCALL_PROC_l' and gateway 'Gateway_l' 

} ACTION 
} STATE 

9 STATE { 
0 SMSC$_Timeout \ timer 'T303' 
ACTI0N{ 

1 n Received timeout 'T3 03' ■ $MSC$_TraceMsg 
0 $MSC$_ResetTimerFlag \ timer 'T303' 
0 $MSC$_ResetGotoModif ierFlag 

20 C $MSC$_NewState 
} ACTION 
?TM_TIMEOUT 
55 ACTION { 
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l ■ Unexpected timer evenc " $MSC$_TraceMsg 

} ACTION 

FALSE E-SAP <3> 0 = OR 
ACTION { 

8 " Unexpected message event " $MSC$_TraceMsg 

} ACTION 
} STATE 



15 



\ document segment ' CALL_PROCEEDING' 

10 STATE { 

" Error while matching primitive 'rALERTl'" 7 0 0 $MSC$_RecvPrimitive 
ACTION { 

0 0 7 $MSC$_FrecEvent Structure \ free event structure of message 
'PROT<ETSI> send to EMUL<isdnI2>/rALERT_l ' and gateway 'Gateway_l' 
0 $MSC$_SetGotoModif ierFIag 

11 0 $MSC$_NewState 
20 } ACTION 

1 $MSC$_Timeout \ timer 'T310' 
ACTION { 

0 0 7 $MSC$_FreeEventStructure \ free event structure of message 
'PROT<ETSI> send to EMUIi<isdnl2>/rAIjERT_l ' and gateway 'Gateway_l* 
25 0 $MSCS_SetGotoMod.if ierFIag 

12 0 $MSC$_NewState 
} ACTION 
?TM_TIMEOUT 

ACTION { 

30 1 » unexpected timer event " $MSC$_TraceMsg 

0 0 7 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to EMUL<isdnl2>/rALERT_l ' and gateway 'Gateway_l' 
} ACTION 

FALSE E-SAP @ 0 - OR 
ACTION { 

8 " Unexpected message event n $MSC$_TraceMsg 

0 0 7 $MSC$_FreeEvent Structure \ free even: structure of message 
'PROT«=ETSI> send to EMUI»< isdnl 2 > / rAIiERT_l ' and gateway 'Gateway_l' 
} ACTION 
} STATE 
11 STATE { 

" Error while matching primitive ' r ALERT_1 ' " 7 0 0 $MSC$_RecvPrimitive 
ACTION { 

8 " Received message ' PROT<ETSI> send to EMUIa<isdnl2>/rALERT_l ' from 
gateway ' Gateway_l ' n $MSC$_TraceMsg 

0 0 7 $MSC$_FreeEvent Structure \ free event structure of message 
'PR0T<ETST> send to EMUL<isdnl 2 > / rAl»ERT_l ' and gateway 'Gateway_l' 
7 $MSC$__ResetMsgFlag \ message 'PR0T<ETSI> send to 
50 EMUL<isdnl2>/rAIiERT_l' from gateway 'Gateway_l J 

0 $MSC$_ResetGotoModif ierFIag 

4 " Timer 'T310' reset" $MSC$_TraceMsg 

1 $MSC$_ResetTimer \ timer 'T31C 
21 0 $MSC$_NewState 

55 ) ACTION 

?TM TIMEOUT 
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action; 

1 M Unexpected timer event * $MSC$_TraceMsg 
} ACTION 

5 FALSE E-SAP @ 0 = OR 



10 
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ACTION{ 

8 " Unexpected message event - $MSC$_TraceMsg 

0 0 7 $MSC$_FreeEventStructure \ free event structure of message 
'PR0T<ETSI> send to EMUL<isdnl2>/rALERT_i' and gateway 'Gateway_l' 

} ACTION 
} STATE 
12 STATE { 

1 $MSC$_Timeout \ timer 'T310' 
ACTION{ 

1 " Received timeout *T310' n $MSC$_TraceMsg 
20 1 $MSC$_ResetTimerFlag \ timer 'T310' 

0 $MSC$_ResetGotoModif ierFlag 
21 0 $MSC$_NevStatR 

} ACTION 
? TM_T T MEOTT 
25 ACTION ( 

1 ■ Unexpected timer event n $MSCS_TraceMsg 
} ACTION 

FALSE E-SAP 9 0 = OR 
ACTION { 

8 " Unexpected message event ■ $MSC$_TraceMsg 
} ACTION 
} STATE 
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\ document segment ' CALL_DELIVERED_ACTIVE' 

13 STATE { 

n Error while matching primitive 'rCONN_l' B 8 0 0 $MSC$_RecvPrimitive 
ACTION{ 

8 11 Received message 'PROT<ETSI> send to EMUL<isdnl2>/rCONN_l' from 
gateway 'Gateway l ' " $MSC$_TraceMsg 

0 0 9 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to 5MUL<isdnl2>/rCONN_i ' and gateway 'Gateway_i' 

8 $MSC$_ResetMsgFlag \ message 'PROT<ETSI> send to 
EMUIj<isdnl2>/rCONN_l' from gateway ' Gateway_l ' 
45 0 $MSC$_ResetGotoModif ierFlag 

2 " Timer ' T_ Call' set with value '20000'" $MSC$_?raceMsg 
20000 2 $MSC$_SetTimer \ timer 'T_Call' 
14 0 $MSC$__NewState 
} ACTION 

50 ? TM_T IMEOUT 

ACTION{ 

1 n Unexpected timer event ■ $MSCS_TraceMsg 
} ACTION 

FALSE E-SAP @ 0 = OR 
ACTION { 

8 " Unexpected message event " $MSCS_TraceMsg 
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0 0 8 $MSC$_FreeEventStructure \ free event structure of message 
'PR0T<STSI> send to EMUL<isdnl2>/rCONN_l ' and gateway 'Gateway_l' 

} ACTION 
} STATE 
14 STATE { 

2 $MSC$_Timeout \ timer 'T_Call' 
action! 

1 - Received timeout 'T_Call' « $MSC$_TraceMsg 

2 $MSC$_ResetTimerFlag \ timer 'T_Call' 
0 $MSC$_ResetGocoModifierFlag 



16 " Send message 'PR0T<ET5I> send to EMUL<isdnl2>/sDISC_l' over 
gateway ' Gateway_l ' " $MSC$_TraceMsg 

n Cannot send message 'sDISCJL'" 9 0 0 $MSC$_SendPrimicive 

2 " Timer 'T305' set with value '30000'" $MSC$_TraceMsg 

30000 3 $MSC$_SetTimer \ timer 'T305' 

22 0 $MSC$_NewState 
} ACTION 
?TM_TIMEOUT 
ACTION { 

1 " Unexpected timer event " $MSC$_TraceMsg 
} ACTION 

FALSE E-SAP ® 0 = OR 
ACT I ON { 

6 » Unexpected message event " $MSC$_TraceMsg 
} ACTION 
} STATE 

\ document segment ' DISCONNECT_REQUEST' 

15 STATE { 

" Error while matching primitive ' rREL_COM_l 10 0 0 
$MSC$_RecvPr imi t i ve 
ACTION} 

0 0 10 $MSC$_FreeEvent Structure \ free event structure of message 
'PRCT<ETSI> send to EMUL<isdnl2>/rREL_COM_l' and gateway 'Gateway_l' 
0 $MSC$_SetGotoModif ierFlag 

16 0 $MSC$_NewState 
} ACTION 

3 $MSC$_Timeout \ timer 'T30 5' 
ACTION { 

0 0 10 $MSC$_Free3vent Structure \ free event structure of message 
'PROT<ETSI> send to EMUL<isdnl2>/rREL_COM__l ' and gateway 'Gateway_l' 

0 $MSC$_SetGotoModif ierFlag 

17 0 $MSC$_NewState 
} ACTION 
?TM_TIMEOUT 

ACTION { 

1 " unexpected timer event " $MSC$_TraceMsg 

0 0 10 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to EMin-<isdnl2>/rREL_COM_l ' and gateway 'Gateway_l' 
} ACTION 

FALSE E-SAP ® 0 = OR 
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ACTION) 

8 " Unexpected message event n $MSC$ JTraceMsg 

0 0 10 $MSC$_FreeEvent Structure \ free event structure of message 
5 ' PR0T<ETSI> send to EMUL<isdnl2>/rREL_COM_l ' and gateway 'Gateway_l' 

} ACTION 
) STATE 
16 STATE { 

■ Error while matching primitive ' rREL_C0M_l ' ■ 10 0 0 
10 $MSC$_RecvPrimitive 
ACTION{ 

8 - Received message 'PR0T<ETSI> send to EMUL<isdnl2>/rREL__COM_l' 
from gateway 'Gateway_l * « $MSC$_TraceMsg 

0 0 10 $MSC$_FreeEvent structure \ free event structure of message 
15 'PR0T<ETSI> send to EMUL<isdnl2>/rREL_COM_l ' and gateway 'Gateway 1' 



10 $MSC$_ResetMsgFlag \ message 'PR0T<ETSI> send to 

20 

EMUL<isdnl2>/rREL_COM_l' from gateway 'Gateway_l' 

0 $MSC$_ResetGotoModifierFlag 
18 0 $MSC$_NewState 

} ACTION 

?TM TIMEOUT 
25 ~ 

ACTION} 

1 " Unexpected timer event " $MSCS_TraceWsg 
} ACTION 

FALSE E-SAP @ 0 = OR 
30 ACTION { 

8 " Unexpected message event " $MSC$_TraceMsg 

0 0 10 $MSC$_FreeSventSt rue cure \ free event structure of message 
'PROT<ETSI> send to EMUL< i s dnl 2 > / r REL_COM_ 1 ' and gateway 'Gateway_l' 

} ACTION 
35 } STATE 

17 STATE { 

3 $MSC$_Timeout \ timer 'T3 05' 
ACTION { 

1 ■ Received timeout 'T305' " SMSCSjrraceMsg 
40 3 $MSC$_ResetTimerFlag \ timer 'T3 05' 

0 $MSCS_ResetGotoModif ierFlag 
18 0 $MSC$_NewState 

} ACTION 
? TM_T IMEOUT 
45 ACTION{ 

1 n Unexpected timer event » $MSC$ JTraceMsg 
} ACTION 

FALSE B-SAP @ 0 = OR 
ACTION { 

8 " Unexpected message event n $MSC$_TraceMsg 
(ACTION 
} STATE 

18 STATE_ I N I T { 

2 - Timer 'T_Pause' set witn value '5000'" $MSC$_TraceMsg 
50C0 4 $MSC$ setTimer \ timer ' T Pause' 
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}STATE_INIT 
18 STATE { 

4 $MSC$_Timeout \ timer 'T_Pause' 

ACTION{ 

1 ■ Received timeout 'T_Pause' " SMSC$_TraceMsg 
4 $MSC$_ResetTimerFlag \ timer 'TPause' 

0 $MSC$_*esetGotoModif ierFLag 

1 0 $MSC$_NewState 
} ACTION 

? TM_T IMEOUT 
ACT ION { 

1 " Unexpected timer event " $MSC$_TraceMsg 
} ACTION 

FALSE E-SAP @ 0 = OR 
ACTIONj 

8 " Unexpected message event " $MSC$ JTraceMsg 
} ACTION 
} STATE 

\ connector segment 'NULL' 



19 STATE_INIT{ 

6 $MSC$_ResetMsgFlag \ message 'PROT<ETSI^ send to 
EMUL<isdnl2>/rCALL_PROC_l ' 

0 $MSC$_ResetTimerFlag \ timer 'T303' 
}STAT3_INIT 
19 STATE { 

" Error while matching primitive ' rCALL_PROC_l ' ■ S 0 0 
$MSC$_RecvPr imit i ve 
ACTION ( 

0 0 6 $MSC$_FreeEventStructure \ free event structure of message 
'PR0T<ETSI> send to EMUL<isdnl2>/ rCALL_PROC_l ' and gateway 'Gateway_l' 
0 $MSC$_SetGotoModif ierFlag 

6 $MSC$_SetMsgFlag \ message 'PR0T<ETSI* send to 
EMUL< i sdnl2>/ rCALL__PROC_l ' 

7 0 $MSC$_NewState 
} ACTION 

0 $MSC$jTimeout \ timer 'T3 03' 

ACTION{ 

0 0 6 $MSC$_FreeEventStruczure \ free event structure of message 
'PROT<ETSl> send zo EMUL<isdnl2>/rCALL_PROC_l' and gateway 'Gateway_l' 

0 $MSC$_SetGotoModif ierFlag 

0 $MSC$_SetTimerFlag \ timer 'T3 03' 

7 0 $MSC$_NewState 
} ACTION 
?TM_T IMEOUT 
ACTION { 

n Unexpected timer event" $MSC$_TraceMsg 
} ACTION 

FALSE E-SAP & 0 = OR 
ACTION { 

■ Unexpected message event" $MSC$_TraceMsg 
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0 0 6 $MSC$_FreeEventStructure \ free event structure of message 
• PROT<ETSI> send to EMUL<isanl2>/rCALL_PROC_l ' and gateway 'Gateway_l' 

} ACTION 
} STATE 

\ connector segment ' CALL_ INITIATED ' 

20 STATE_INIT{ 

7 $MSC$_ResetMsgFlag \ message 'PR0T<ETSI> send to 
EMUL <isdnl2>/ r ALERT_1 ' 

1 $MSC$_ResetTimerFlag \ timer 'T310' 
} STATE_INIT 

20 STATE { 

w Error while matching primitive ' rALERT_l' " 7 0 0 $MSC$_RecvPrimit ive 
ACTION { 

0 0 7 $MSC$_FreeEvent Structure \ free event structure of message 
'PR0T<ETSI> send to EMUL<isdnl2>/rAliERT_l ' and gateway 'Gateway_l' 
0 $MSC$_Set3otoModif ierFlag 

7 $MSC$_SetMsgFlag \ message 'PR0T<ETSI> send to 
EMUL< i sdni 2 > / rALERT_l ' 

10 0 $MSC$_NewState 
} ACTION 

1 SMSC$_Timeout \ timer 'T310' 
ACTION { 

0 0 7 $MSC$_FreeEvenc Structure \ free event structure of message 
'PROT<ETSI> send to 3MUL<isdnl2>/rALERT_l ' and gateway 'Gateway_l' 



0 $MSC$_SetGotoModif ierFlag 

1 $MSC$_SetTimerFlag \ timer 'T310' 
10 0 $MSC$_NewState 

}ACTI0N 
?7M_TIMECUT 
ACTION { 

n Unexpected timer event" $MSC$_TraceMsg 
} ACTION 

FALSE E-SAP ® 0 - OR 
ACTION { 

" Unexpected message event" $MSC$_TraceMsg 

0 0 7 $MSC$__FreeEventStructure \ free event structure of message 
' PROT<ETSI> send to EWUL<isdnl2>/rALERT_l ' and gateway 'Gateway_l' 
}ACTION 
} STATE 

\ connector segment ' CALL_?ROCEED I NG ' 

21 STATE_INIT{ 

8 $MSC$_ResetMsgFlag \ message « PROT<ETSI> send to 
EMUL<isdnl2>/rC0NW_l' 
}STATE_INIT 
21 STATE { 

" Error while matching primitive 'rCOMN__l' n 8 0 0 $MSC$_RecvPrimitive 
ACTI0N{ 

0 0 8 $MSC$_FreeEvent Structure \ free event structure of message 
' PROT<ETSI> send to EMI7L<isdnl2>/rC0NN_l' and gateway ' Gateway_l ' 
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0 $MSC$_SetGotoModi f ierFlag 

8 $MSC$_SetMsgFlag \ message ' PROT<ETSI> send to 
BMULc i sdnl 2 > / rCONN_l ' 

13 0 $MSC$_NewState 
} ACTION 
?TM_T IMEOUT 
ACTION { 

■ Unexpected timer event" $MSC$_TraceMsg 
10 ) ACTION 

FALSE E-SAP @ 0 = OR 
ACTION{ 

" Unexpected message event" $MSC$_TraceMsg 

0 0 8 $MSC$_FreeEventStructure \ free event structure of message 
15 'PR0T<ETSI> send to EMUX<isdnl2>/rC0NN_l ' and gateway 'Gateway_l' 

}ACTION 
} STATE 

\ connector segment ' CALL_BELIVERED__ACTIVE' 

20 22 STATE_INIT{ 

10 $MSC$_KesetMsgFlag \ message 'PR0T<ETSI> send to 
EMUL< i Sdnl2 > / rREL_C0M_l ' 

3 $MSC$_ResetTimerFlag \ timer 'T305' 
} STATE_INIT 
25 22 STATE { 

■ Error while matching primitive ' rREL_COM_l ' n 10 0 0 
$MSCS_ RecvPrimitive 

ACTION { 

0 0 10 $M£C$ FreeEventstructure \ free event structure of message 
30 ~ 

'PR07<ETSI> send to EMUL<isdnl2>/rREL_COM_l ' and gateway 'GatewayJL* 

0 $MSC$_SetGotoModif ierFlag 



35 10 $MSC$_SetMsgFlag \ message 'PROT<ETSI> send to 

EMUL< isdn!2 > / rREL_COM_l ' 

15 0 $MSCS_NewState 
} ACTION 

3 $MSC$_Timeout \ timer 'T305' 
40 ACTION { 

0 0 10 $MSC$_FreeEvent Structure \ free event structure of message 
'PROT<ETSI> send to BMUL<isdnl2>/rREL_C0M_ > l ' and gateway 'GatewayjL' 
0 $MSC$_setGotoModif ierFlag 
3 $MSC$_SetTinerFlag \ timer 'T3 05' 
45 15 o $MSC$_NewState 

} ACTION 
?TM_T IMEOUT 
ACTION{ 

" Unexpected timer event" $MSC$_TraceMsg 
50 } ACTION 

FALSE E-SAP @ 0 = OR 
ACTION { 

■ Unexpected message event" $MSC$_TraceMsg 

0 0 10 $MSC$_FreeEventstructure \ free event structure of message 
55 ' PROT<ETSI=. send to EMUL<isdnl2>/rREL__COM_l' and gateway 'Gateway_l' 
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} ACTION 
} STATE 

( >>>>>>>>>> end of instance 'Phone' <<<<<<<<<< ) 

5 

$MSC$_Cons tractor 

MSC_MENU_CTRL_FCT ( calls the menu control function ) 
n MSC scenario ' isdn__user' loaded" $MSC$_PrintString 

10 



Patentanspruche 

15 

1. Verfahren zum Erstellen eines Ablaufs einer zwischen mindestens zwei Instanzen ablaufenden Kommunikation, 
wobei eine Instanz ein Protokolltester ist, gekennzeichnet durch folgende, am Protokolltester ausfuhrbare Schritte: 

a) Auswahlen der an der Kommunikation beteiligten Instanzen; 
20 b) Auswahlen einer Protokollschicht auf deren Grundlage die Kommunikation zwischen den ausgewahlten 

Instanzen ablaufen soil; 

c) Auswahlen derjenigen abstrakten Kommunikationsschnittstellen der Protokollschicht, die an der Kommu- 
nikation betetligt sind; 

d) Auswahlen der Kommunikationsdaten: 

25 e) automatisches Erstellen eines zwischen den mindestens zwei Instanzen ausfuhrbaren Kommunikations- 

ablaufs durch den Protokolltester, auf der Grundlage der Auswahlen in den Schritten a) bis d), 

wobei die Auswahl von Schritt c) und/oder Schritt d) graphisch erfolgt und den dabei auswahibaren Parametern 
Beschreibungsdateienzugeordnetsind, die in Schritt e) zur Ersteliung eines zwischen den Instanzen ausfuhrbaren 
30 Kommunikationsablaufs verwendet werden. 

2. Verfahren nach Anspruch 1 , 
dadurch gekennzeichnet, 

daB weiterhin in Schritt a) die an der Kommunikation beteiligten Instanzen graphisch ausgewahlt werden und/oder 
35 in Schritt b) die Protokollschicht graphisch ausgewahlt wird und den dabei auswahibaren Parametern Beschrei- 

bungsdateien zugeordnet sind, die in Schritt e) zur Ersteliung eines zwischen den Instanzen ausfuhrbaren Kom- 
munikationsablaufs verwendet werden. 

3. Verfahren nach Anspruch 1 Oder 2, 
40 dadurch gekennzeichnet, 

daf3 die abstrakten Kommunikationsschnittstellen SAPs (Service Access Points) umfassen. 

4. Verfahren nach einem der vorhergehenden Anspruche, 
dadurch gekennzeichnet, 

45 daBdie Kommunikationsdaten PDUs (Protocol Data Units) und/oder ASPs (Abstract Service Primitives) umfassen. 

5. Verfahren nach einem der vorhergehenden Anspruche, 
dadurch gekennzeichnet, 

da3 Schritt d) folgende Teilschritte umfaf3t: 

50 

d1) graphisches Auswahlen eines Datenformats; 

d2) graphischer Aufbau einer Kommunikationsabfolgc zwischen den beteiligten Instanzen. 

6. Verfahren nach Anspruch 5, 
55 dadurch gekennzeichn t, 

daB in Schritt 62) Source-Code eingebbar ist. 

7. Verfahren nach einem der vorhergehenden Anspruche, 
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dadurch gekennzeichnet, 

da3 alien auswahlbaren Parametern Beschreibungsdateien zugeordnet sind, die in Schritt e) zur Erstellung elnes 
zwischen den Instanzen ausfuhrbaren Kommunikationsablaufs verwendet werden. 

Protokolltester mit 

a) Mitteln zum Auswahlen der an einer Kommunikation beteiligten Instanzen (19, 20, 24, 26), wobei eine der 
Instanzen der Protokolltester ist; 

b) Mitteln zum Auswahlen einer Protokollschicht (20 : 28a), auf deren Grundlage die Kommunikation zwischen 
den ausgewahlten Instanzen ablaufen soli; 

c) Mitteln zum Auswahlen derjenigen abstrakten Kommunikationsschnittstellen (20, 32a) der Protokollschicht, 
die an der Kommunikation beteiligt sind; 

d) Mitteln zum Auswahlen der Kommunikationsdaten (20, 34); 

e) Mitteln zum automatischen Erstellen eines zwischen den Instanzen ausfuhrbaren Kommunikationsablaufs 
durch den Protokolltester, auf der Grundlage der Auswahlen gemaB a) bis d), 

wobei die Auswahlmittel gemaB c) und/oder gemaB d) graph ische Auswahlmittel sind und den durch sie auswahl- 
baren Parametern Beschreibungsdateien zugeordnet sind, die gemaB e) von den Erstellungsmittelnzur Erstellung 
eines zwischen den InsLanzen ausfuhrbaren Kommunikationsablaufs verwendbar sind. 

Protokolltester nach Anspruch 8, 
dadurch gekennzeichnet, 

daBdie Mittel zum Auswahlen der an der Kommunikation beteiligten Instanzen (19, 20, 24,26) und/oder die Mittel 
zum Auswahlen der Protokollschicht (20, 28a) graphische Auswahlmittel sind und den durch sie auswahlbaren 
Parametern Beschreibungsdateien zugeordnet sind, die gemaB e) von den Erstellungsmitteln zur Erstellung eines 
zwischen den Instanzen ausfuhrbaren Kommunikationsablaufs verwendbar sind. 

0. Protokolltester nach einem der Anspruche 8 oder 9, 
dadurch gekennzeichnet, 

daB die abstrakten Kommunikationsschnittstellen SAPs (Service Access Points) umfassen. 

1. Protokolltester nach einem der Anspruche 8 bis 10, 
dadurch gekennzeichnet, 

daB die Kommunikationsdaten PDUs (Protocol Data Units) und/oder ASPs (Abstract Service Primitives) umfassen. 

2. Protokolltester nach einem der Anspruche 8 bis 11 , 
dadurch gekennzeichnet, 

daB er Mittel zum Eingeben von Source-Code (44, 46) umfaBt. 

3. Protokolltester nach einem der Anspruche 8 bis 12, 
dadurch gekennzeichnet, 

daB alien mit den Auswahlmitteln auswahlbaren Parametern Beschreibungsdateien zugeordnet sind, die gemaB 
e) von den Erstellungsmitteln zur Erstellung eines zwischen den Instanzen ausfuhrbaren Kommunikationsablaufs 
verwendbar sind. 
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A method of setting up a communication procedure between 
instances, one of which is a protocol tester that uses the 
method, includes the steps of selecting the instances, select- 
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selecting abstract communication interfaces for the protocol 
layer- selecting communication data and automatically set- 
ting up the communication procedure on the basis ot the 
results of the selecting steps. Any of the selecting steps may 
be performed graphically, and parameters selected are 
assigned description files that are used in the setting up step. 
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SETTING UP A COMMUNICATION PROCEDURE 
BETWEEN INSTANCES AND A PROTOCOL 
TESTER USING THE METHOD 

BACKGROUND OF THE INVENTION 

[0001] The present invention relates to protocol testing, 
and more particularly to a method of setting up a commu- 
nication procedure between instances, with one of the 
instances being a protocol tester, and to a protocol tester 
using the method. 

[0002] In the field of protocol testing it is necessary to 
clearly specify a communication procedure by which a test 
is described so that the procedure may be executed auto- 
matically by a protocol tester. Languages such as TTCN 
(Tree and Tabular Combined Notation) make this possible, 
but they are complex and difficult to understand for an 
untrained reader. TTCN has prevailed in the field of Con- 
formance Testing because these tests are very comprehen- 
sive, and TTCN supports such comprehensive tests very 
well. Apart from that, there are various proprietory test 
description languages. To facilitate understanding a stan- 
dardized language, MSC (Message Sequence Charts), is 
used for the purpose of documenting and describing simple 
procedures. Further details on MSC may be taken from 
ITU-T Z.120, the contents of which are incorporated herein 
by reference. MSC consists of standardized process flow 
diagrams, also referred to as arrow diagrams or X diagrams. 
These diagrams may be understood independent of program- 
ming language. However, automatic execution of commu- 
nications described by MSC is not possible on protocol 
testers. To obtain tests that are executable it is, therefore, 
necessary to write so-called "scripts", which requires that 
the user becomes thoroughly acquainted with the relevant 
programming language. In addition it is necessary to prepare 
documentation that is generally understood. For a test it is, 
therefore, necessary on the one hand to prepare graphical 
and textual documentation and on the other hand a source 
code or binary code that may be executed. 

[0003] This state of the art results in a number of disad- 
vantages. It is frequently necessary to convert existing tests, 
so there is a risk of inconsistencies. The test communication 
specifications often do not contain information on the con- 
figuration, or at least not in a format that may be read by a 
machine or by man. The different languages often represent 
proprietary approaches, which differ from equipment to 
equipment and have to be learned anew. The user is not 
supported or only receives rudimentary support with proto- 
col knowledge when creating the messages and events. 
[0004] What is desired is a method, and protocol tester 
using the method, that overcomes the above-noted disad- 
vantages. 

BRIEF SUMMARY OF THE INVENTION 

[0005] Accordingly the present invention provides a 
method of setting up a communication procedure between 
instances, one of which is a protocol tester, by executing the 
following steps on the protocol tester: selecting instances 
that are to take part in the communication procedure; 
selecting a protocol layer on the basis of the communication 
procedure; selecting abstract communication interfaces of 
the protocol layer for the communication procedure; select- 
ing communication data; and automatically setting up 



through the protocol tester on the basis of the above selec- 
tions the communication procedure. The selections at any 
one of the steps may be made graphically with parameters 
selected being assigned description files that are used in the 
setting up step. 

[0006] The objects, advantages and other novel features of 
the present invention are apparent from the following 
detailed description when read in conjunction with the 
appended claims and attached drawing. 

BRIEF DESCRIPTION OF THE SEVERAL 
VIEWS OF THE DRAWING 

[0007] FIG. 1 is a plan view of a first graphical user 
interface (GUI) for a method according to the present 
invention. 

[0008] FIG. 2 is a plan view of a second GUI for a method 
according to the present invention. 
[0009] FIG. 3 is a plan view of the second GUI of FIG. 
2 in another presentation mode. 

[0010] FIG. 4 is a plan view of the second GUI of FIG. 
2 in a further presentation mode. 

[0011] FIG. 5 is a plan view of a third GUI for a method 
according to the present invention. 
[0012] FIG. 6 is a plan view of the third GUI of FIG. 5 
in another presentation mode. 

[0013] FIG. 7 is a plan view of the third GUI of FIG. 5 
in a further presentation mode. 

DETAILED DESCRIPTION OF THE 
INVENTION 

[0014] FIG. 1 shows a graphical user interface (GUI) 10 
that allows in a first step graphically selecting instances 
taking part in a communication procedure. Graphical selec- 
tion in connection means that a symbol or a text proposal is 
shown graphically on the GUI, such as on a personal 
computer (PC) screen, and may be selected by simple 
activation, i.e., by clicking on it with a "mouse " One of the 
instances is a protocol tester on which the method as 
described herein is made available, with the protocol tester 
in the present case emulating a component, TC__1. Using 
two buttons, "Add"12 and "Delete"14, a user may add 
further instances or delete instances listed. In a field 16 the 
compilation of instances is listed, while in another field 18 
the compilation is shown as a diagram. In another field 19 
the name of the instance may be selected, and in a further 
field 20 the instance type is shown. Two buttons, "Back"22 
and "Next"24, allow the user to move from one level of the 
definition of the communication procedure to the next, both 
in the direction of more detailed specifications and in the 
direction of higher-level presentations. A "Cancel" button 26 
allows leaving a level, meaning that the changes made are 
reset. A "Help" button 28 offers the user further support. 
[0015] According to FIG. 2, which shows another repre- 
sentation of the GUI 10, the present communication proce- 
dure has the name Gateway_l, as shown in field 23. Taking 
part in the procedure is a first instance TC_1, according to 
field 25, and a second instance IUT__1, according to field 27. 
According to field 29a the emulated protocol is of the type 
"isdnl2", with field 29b offering further protocols from 
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which to choose. In field 30 various communication proce- 
dures that may be chosen for further processing may be 
offered. Buttons 12, 14, 22, 24, 26, 28 described with 
reference to FIG. 1 appear again in similar form and with 
similar functions. 

[0016] FIG. 3 shows the GUI of FIG. 2 in a different 
presentation mode, in this case for selecting a Service 
Access Point (SAP), as shown in field 32a. In field 32b there 
are further SAPs from which to choose. All SAPs shown in 
field 32b are offered for the selected emulation "isdnl2." 

[0017] FIG. 4 shows another presentation form of the GUI 
10 of FIG. 2, with a format for the communication data 
(Abstract Service Primitives— ASPs, Protocol Data Units—- 
PDUs) now being used in a field 34 having so-called 
Message Pools. 

[0018] FIG. 5 shows another GUI 36 that provides the 
user with various types of information in a field 38. First the 
instances selected by the user, then the test scenario (Gate- 
way__l) agreed in accordance with FIGS. 1-4, and finally 
the data format (Message Pools). 

[0019] The following initially only refers to FIG. 6. The 
GUI 36 shows a large number of buttons 40 that, as is known 
from word processing or graphics programs, may be clicked 
by using a mouse. Using these buttons 40 the user may 
graphically set up the communication procedure in field 42. 
FIG. 6 shows the possibility of incorporating codes in the 
programming language Forth (Draft Proposal ANSI Stan- 
dard 1994) into a block TE_cfg 44 by using an entry mask 
46. To enter codes in another programming language other 
entry masks may be used. 

[0020] Returning to FIG. 5 as an example of a part of the 
communication procedure shown in field 48, an instance is 
awaiting, initially alternatively, the ASPs DL_ESTABLISH- 
_CNF__1 or DL_ESTABLISH_IND_1 . Next a timer 
T_Waitinit with a five (5) second duratioin is started and the 
elapsing of the time is awaited. 

[0021] FIG. 7 shows an isdn-PDU "SETUP_1" being 
incorporated into a flow diagram prepared graphically as a 
send message. ASPs with PDUs from the Message Pool 
selected earlier are offered in an entry mask 50. The PDU 
selected may be entered into a visually highlighted field 52. 
In a field 54 the user is offered further information on the 
ASP or PDU selected. 

[0022] In this way it is possible to set up the communi- 
cation procedure, with preferably all selectable parameters 
being assigned description files that may be used with each 
other to automatically set up through the protocol tester the 
communication procedure to be executed between the 
instances. 

[0023] When a code that may be executed is created, there 
are three interacting components. First the GUI stores the 
selected parameters, in particular the communication 
sequence, in an internal structure. Then a compiler translates 
the selected parameters into temporary files. Finally a linker 
reads the temporary files and converts them into the selected 
interpreter script language, such as ANS Forth. During this 
process the communication procedure as defined by the user 
is written into a script file. 

[0024] Annex Al shows the code automatically generated 
by the protocol tester for the figures described. 



What is claimed is: 

1. A method of setting up a communication procedure 
between instances, with one instance being a protocol tester, 
comprising the steps of: 

selecting the instances that take part in the communication 
procedure; 

selecting a protocol layer on the basis of the communi- 
cation procedure; 

selecting abstract communication interfaces of the proto- 
col layer for the communication procedure; 

selecting communication data; and 

automatically setting up through the protocol tester the 
communication procedure on the basis of the selections 
made in the above selecting steps, with the abstract 
communication interfaces selecting and/or the commu- 
nication data selecting steps being made graphically 
and parameters selectable during these steps being 
assigned description files that are used in the setting up 
step to set up the communication procedure. 

2. The method as recited in claim 1 wherein the instances 
selecting step comprises the step of selecting the instances 
graphically, and/or the protocol layer selecting step com- 
prises the step of selecting the protocol layer graphically, 
and the parameters selectable in these steps being assigned 
description files that are used in the setting up step. 

3. The method as recited in claims 1 or 2 wherein the 
abstract communication interfaces comprise Service Access 
Points (SAPs). 

4. The method as recited in claim 3 wherein the commu- 
nication data comprise at least one type selected from the 
group consisting of Protocol Data Units (PDUs) and 
Abstract Service Primitives (ASPs). 

5. The method as recited in claims 1 or 2 wherein the 
communication data comprise at least one type selected 
from the group consisting of Protocol Data Units (PDUS) 
and Abstract Service Primitives (ASPs). 

6. The method as recited in claim 1 wherein the commu- 
nication data selecting step comprises the steps of: 

graphically selecting a data format; and 

graphically setting up a communication sequence 
between the selected instances. 

7. The method as recited in claim 6 wherein the graphi- 
cally setting up step comprises the step of entering source 
code. 

8. A protocol tester comprising: 

means for selecting instances taking part in a communi- 
cation procedure, one of the instances being the pro- 
tocol tester; 

means for selecting a protocol layer on the basis of the 
communication procedure; 

means for selecting abstract communication interfaces of 
the protocol layer for the communication procedure; 

means for selecting communication data; and 

means for automatically setting up the communication 
procedure through the protocol tester on the basis of the 
selections of the various selecting means, with the 
abstract communication interfaces selecting means 
and/or the communication data selecting means being 
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graphical selecting means and parameters selected by 
the various selecting means being assigned description 
files that are used in the automatically setting up means 
for setting up the communication procedure. 

9. The protocol tester as recited in claim 8 wherein the 
instances selecting means and/or the protocol layer selecting 
means comprise graphical selecting means and the param- 
eters selected by these selecting means are assigned descrip- 
tion files that are used in the automatically setting up means. 

10. The protocol tester as recited in claims 8 or 9 wherein 
the abstract communication interfaces comprise Service 
Access Points (SAPs). 



11. The protocol tester as recited in claim 10 wherein the 
communication data comprises one type selected from the 
group consisting of Protocol Data Units (PDUs) and 
Abstract Service Primitives (ASPs). 

12. The protocol tester as recited in claim 11 further 
comprising means for entering source codes. 

13. The protocol tester as recited in claim 8 wherein all 
parameters selected by all the selecting means are assigned 
description files that are used by the setting up means. 

***** 



